<script setup lang="ts">
  interface IProps {
    /** 是否在左侧显示一个标题 */
    title?: string
    /** 是否在右侧实现一个箭头 */
    showArrow?: boolean
    /** 是否自定义样式, 接受一个样式对象 */
    customStyle?: object
  }
  const { title = '', showArrow = false, customStyle = {} } = defineProps<IProps>()
</script>

<template>
  <view class="custom-section" :style="{ ...customStyle }">
    <view class="custom-section-header">
      <view class="section-header-title">{{ title }}</view>
      <view class="section-header-right">
        <slot name="right"></slot>
        <uni-icons v-if="showArrow" color="#c3c3c5" size="16" type="forward" />
      </view>
    </view>
    <slot></slot>
  </view>
</template>

<style lang="scss">
  .custom-section {
    padding: 40rpx 30rpx 30rpx;
    margin-bottom: 20rpx;
    background-color: #fff;
    border-radius: 20rpx;
  }

  .custom-section-header {
    display: flex;
    justify-content: space-between;
    line-height: 1;
    margin-bottom: 20rpx;
  }

  .section-header-title {
    font-size: 32rpx;
    color: #333;
  }

  .section-header-right {
    display: flex;
    align-items: center;
    font-size: 26rpx;
    color: #c3c3c5;
  }
</style>
